# TECHNICAL REPORT

### ISO/IEC TR 14496-9

Second edition 2008-08-15

## Information technology — Coding of audio-visual objects —

Part 9:

Reference hardware description

Technologies de l'information — Codage des objets audiovisuels — Partie 9: Description de matériel de référence



#### PDF disclaimer

This PDF file may contain embedded typefaces. In accordance with Adobe's licensing policy, this file may be printed or viewed but shall not be edited unless the typefaces which are embedded are licensed to and installed on the computer performing the editing. In downloading this file, parties accept therein the responsibility of not infringing Adobe's licensing policy. The ISO Central Secretariat accepts no liability in this area.

Adobe is a trademark of Adobe Systems Incorporated.

Details of the software products used to create this PDF file can be found in the General Info relative to the file; the PDF-creation parameters were optimized for printing. Every care has been taken to ensure that the file is suitable for use by ISO member bodies. In the unlikely event that a problem relating to it is found, please inform the Central Secretariat at the address given below.





#### **COPYRIGHT PROTECTED DOCUMENT**

#### © ISO/IEC 2008

All rights reserved. Unless otherwise specified, no part of this publication may be reproduced or utilized in any form or by any means, electronic or mechanical, including photocopying and microfilm, without permission in writing from either ISO at the address below or ISO's member body in the country of the requester.

ISO copyright office
Case postale 56 • CH-1211 Geneva 20
Tel. + 41 22 749 01 11
Fax + 41 22 749 09 47
E-mail copyright@iso.org
Web www.iso.org

Published in Switzerland

| <b>Contents</b> Page |                                                                                                                                                                           |       |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| Forewo               | ord                                                                                                                                                                       | v     |
| Introdu              | uction                                                                                                                                                                    | vii   |
| 1                    | Scope                                                                                                                                                                     | 1     |
| 2                    | Copyright disclaimer for HDL software modules                                                                                                                             | 1     |
| _                    | Abbreviated terms                                                                                                                                                         |       |
| 3                    | HDL software availability                                                                                                                                                 | 2     |
| 4                    | HDL software availability                                                                                                                                                 | 2     |
| 5                    | HDL coding format and standards                                                                                                                                           | 2     |
| 5.1                  | HDL standards and libraries                                                                                                                                               | 2     |
| 5.2<br>5.3           | Conditions and tools for the synthesis of HDL modules                                                                                                                     | 3     |
|                      |                                                                                                                                                                           | s     |
| 6                    | Integrated Framework supporting the "Virtual Socket" between HDL modules described                                                                                        | ,     |
| 6.1                  | in Part 9 and the MPEG Reference Software (Implementation 1)                                                                                                              | <br>ಇ |
| 6.2                  | Introduction                                                                                                                                                              | 4     |
| 6.3                  | Memory Map                                                                                                                                                                | 4     |
| 6.4                  | Hardware Accelerator Interface User Hardware Accelerator Sockets                                                                                                          | 6     |
| 6.5                  | User Hardware Accelerator Sockets                                                                                                                                         | 12    |
| 7                    | Integrated Framework supporting the "Virtual Socket" between HDL modules described in Part 9 and the MPEG Reference Software (Implementation 2)                           | 14    |
| 7.1                  | Introduction                                                                                                                                                              | 14    |
| 7.2                  | Development Example of a Typical Module : Calc_Sum_Product Module                                                                                                         | 14    |
| 7.3                  | Second Example of a Typical Module : fifo_transfer module                                                                                                                 | 19    |
| 7.4                  | Integrating the Multi-Modules within the Framework                                                                                                                        |       |
| 7.5<br>7.6           | Calc_Sum_Product Module Controller (memory data transfer)                                                                                                                 |       |
| 7.7                  | Debug Menú                                                                                                                                                                | 45    |
| 8                    | Integrated Framework supporting the "Virtual Socket" between HDL modules described                                                                                        |       |
| 8.1                  | in Part 9 and the MPEG Reference Software (Implementation 3)                                                                                                              |       |
| 8.2                  | Reference for Virtual Socket API Function Calls                                                                                                                           |       |
| 8.3                  | Tutorial on the Integrated Virtual Socket Hardware-Accelerated Co-design Platform for                                                                                     |       |
|                      | MPEG-4 Part 9 Implementation 3                                                                                                                                            | 98    |
| 8.4                  | An Integration of the MPEG-4 Part 10/AVC DCT/Q Hardware Module into the Virtual                                                                                           |       |
| 0.5                  | Socket Co-design Platform                                                                                                                                                 | 142   |
| 8.5                  | Migrating Virtual Socket Hardware-Accelerated Co-design Platform From WildCard-II to WildCard-4                                                                           | 155   |
| 9                    | Integrated Framework supporting the "Virtual Socket" between HDL modules described in Part 9 and the MPEG Reference Software: Implementation 4 - Virtual Memory Extension |       |
| 9.1                  | Introduction                                                                                                                                                              |       |
| 9.2                  | Overview of the "Virtual Socket Platform" implementation 4                                                                                                                | 168   |
| 9.3                  | Development information                                                                                                                                                   | 172   |
| 9.4                  | Technical details                                                                                                                                                         |       |
| 9.5                  | How to build the platform                                                                                                                                                 |       |
| 9.6<br>9.7           | Simulation of the platform                                                                                                                                                |       |
| 9. <i>1</i><br>9.8   | Building the platform system software                                                                                                                                     |       |
| 9.9                  | How to use the platform.                                                                                                                                                  |       |

#### ISO/IEC TR 14496-9:2008(E)

| 9.10    | Understanding VHDL code                                                        | .216        |
|---------|--------------------------------------------------------------------------------|-------------|
| 9.11    | Appendix                                                                       | .221        |
| 9.12    | Glossary                                                                       | .223        |
| 10      | HDL MODULES                                                                    | 226         |
| 10.1    | INVERSE QUANTIZER HARDWARE IP BLOCK FOR MPEG-4 PART 2                          |             |
| 10.1    | 2-D IDCT HARDWARE IP BLOCK FOR MPEG-4 PART 2                                   | _           |
| 10.2    | VLD+IQ+IDCT for MPEG-4                                                         |             |
| 10.3    | A SYSTEM C MODEL FOR 2X2 HADAMARD TRANSFORM AND QUANTIZATION FOR               | .242        |
| 10.4    | MPEG-4 PART 10MPEG-4 PART 10                                                   | 247         |
| 10.5    | A VHDL HARDWARE BLOCK FOR 2X2 HADAMARD TRANSFORM AND QUANTIZATION              | .241        |
| 10.5    | WITH APPLICATION TO MPEG-4 PART 10 AVC                                         | 255         |
| 10.6    | A SYSTEMC MODEL FOR 4X4 HADAMARD TRANSFORM AND QUANTIZATION FOR                | .200        |
| 10.0    | MPEG-4 PART 10                                                                 | 261         |
| 10.7    | A VHDL HARDWARE IP BLOCK FOR 4X4 HADAMARD TRANSFORM AND QUANTIZATION           | .201        |
| 10.7    | FOR MPEG-4 PART 10 AVC                                                         | 269         |
| 10.8    | A HARDWARE BLOCK FOR THE MPEG-4 PART 10 4X4 DCT-LIKE TRANSFORMATION            | .203        |
| 10.0    | AND QUANTIZATION                                                               | 275         |
| 10.9    | A SYSTEMC MODEL FOR THE MPEG-4 PART 10 4X4 DCT-LIKE TRANSFORMATION AND         | .213        |
| 10.9    | QUANTIZATIONQUANTIZATION                                                       | 281         |
| 10.10   | A 8X8 INTEGER APPROXIMATION DCT TRANSFORMATION AND QUANTIZATION                | .201        |
| 10.10   | SYSTEMC IP BLOCK FOR MPEG-4 PART 10 AVC                                        | 280         |
| 10.11   | INTEGER APPROXIMATION OF 8X8 DCT TRANSFORMATION AND QUANTIZATION, A            | .203        |
| 10.11   | HARDWARE IP BLOCK FOR MPEG-4 PART 10 AVC                                       | 200         |
| 10.12   | A VHDL CONTEXT-BASED ADAPTIVE VARIABLE LENGTH CODING (CAVLC) IP BLOCK          | .233        |
| 10.12   | FOR MPEG-4 PART 10 AVC                                                         | 306         |
| 10.13   | A VERILOG HARDWARE IP BLOCK FOR SA-DCT FOR MPEG-4                              | .300<br>311 |
| 10.13   | A VERILOG HARDWARE IP BLOCK FOR SA-DCT FOR MPEG-4                              |             |
| 10.15   | A VERILOG HARDWARE IP BLOCK FOR 2D-DCT (8X8)                                   |             |
| 10.16   | SHAPE CODING BINARY MOTION ESTIMATION HARDWARE ACCELERATION MODULE             |             |
| 10.17   | A SIMD ARCHITECTURE FOR FULL SEARCH BLOCK MATCHING ALGORITHM                   |             |
| 10.17   | HARDWARE MODULE FOR MOTION ESTIMATION (4xPE)                                   |             |
| 10.19   | A IP BLOCK FOR H.264/AVC QUARTER PEL FULL SEARCH VARIABLE BLOCK MOTION         | .001        |
| 10.10   | ESTIMATION                                                                     | 381         |
| 10.20   | AN IP BLOCK FOR VARIABLE BLOCK SIZE MOTION ESTIMATION IN H.264/MPEG-4 AVC      | 390         |
| 10.21   | An IP Block for AVC Deblocking Filter                                          |             |
| _       |                                                                                | 00          |
| Annex   | A (Informative) Specification of directory structure for reference SW, HDL and |             |
|         | documentation files of MPEG-4 Part 9 Reference HW Description                  |             |
| A.1     | Introduction,                                                                  |             |
| A.2     | Directory Structure of TR SW Modules                                           | .409        |
| A.3     | Additional Section in Contribution Document (e.g. SA-DCT)                      |             |
| CVS M   | odule Name                                                                     | .410        |
|         | ition Framework Version                                                        |             |
| Refere  | nce Software Version and Modifications                                         | .411        |
| Annex   | B (Informative) Tutorial on Part 9 CVS Client Installation & Operation         | 412         |
| B.1     | Introduction                                                                   |             |
| B.2     | Tools for accessing the EPFL CVS repository                                    |             |
| B.3     | Basic CVS commands                                                             |             |
|         |                                                                                |             |
| Annex   | C (Informative) Additional utility software                                    | .422        |
| Annex   | D (Informative) Providers of reference hardware code                           | .423        |
|         | •                                                                              |             |
| Bibliog | raphy                                                                          | .424        |

#### **Foreword**

ISO (the International Organization for Standardization) and IEC (the International Electrotechnical Commission) form the specialized system for worldwide standardization. National bodies that are members of ISO or IEC participate in the development of International Standards through technical committees established by the respective organization to deal with particular fields of technical activity. ISO and IEC technical committees collaborate in fields of mutual interest. Other international organizations, governmental and non-governmental, in liaison with ISO and IEC, also take part in the work. In the field of information technology, ISO and IEC have established a joint technical committee, ISO/IEC JTC 1.

International Standards are drafted in accordance with the rules given in the ISO/IEC Directives, Part 2.

The main task of the joint technical committee is to prepare International Standards. Draft International Standards adopted by the joint technical committee are circulated to national bodies for voting. Publication as an International Standard requires approval by at least 75 % of the national bodies casting a vote.

In exceptional circumstances, the joint technical committee may propose the publication of a Technical Report of one of the following types:

- type 1, when the required support cannot be obtained for the publication of an International Standard, despite repeated efforts;
- type 2, when the subject is still under technical development or where for any other reason there is the future but not immediate possibility of an agreement on an International Standard;
- type 3, when the joint technical committee has collected data of a different kind from that which is normally published as an International Standard ("state of the art", for example).

Technical Reports of types 1 and 2 are subject to review within three years of publication, to decide whether they can be transformed into International Standards. Technical Reports of type 3 do not necessarily have to be reviewed until the data they provide are considered to be no longer valid or useful.

Attention is drawn to the possibility that some of the elements of this document may be the subject of patent rights. ISO and IEC shall not be held responsible for identifying any or all such patent rights.

ISO/IEC TR 14496-9, which is a Technical Report of type [3], was prepared by Joint Technical Committee ISO/IEC TC 1, Information technology, Subcommittee SC 29, Coding of audio, picture, multimedia and hypermedia information.

This second edition cancels and replaces the first edition (ISO/IEC TR 14496-9:2004) which has been technically revised.

ISO/IEC TR 14496 consists of the following parts, under the general title *Information technology* — *Coding of audio-visual objects*:

- Part 1: Systems
- Part 2: Visual
- Part 3: Audio
- Part 4: Conformance testing
- Part 5: Reference software

#### ISO/IEC TR 14496-9:2008(E)

- Part 6: Delivery Multimedia Integration Framework (DMIF)
- Part 7: Optimized reference software for coding of audio-visual objects [Technical Report]
- Part 8: Carriage of ISO/IEC 14496 contents over IP networks
- Part 9: Reference hardware description [Technical Report]
- Part 10: Advanced Video Coding
- Part 11: Scene description and application engine
- Part 12: ISO base media file format
- Part 13: Intellectual Property Management and Protection (IPMP) extensions
- Part 14: MP4 file format
- Part 15: Advanced Video Coding (AVC) file format
- Part 16: Animation Framework eXtension (AFX)
- Part 17: Streaming text format
- Part 18: Font compression and streaming
- Part 19: Synthesized texture stream
- Part 20: Lightweight Application Scene Representation (LASeR) and Simple Aggregation Format (SAF)
- Part 21: MPEG-J Graphics Framework eXtensions (GFX)
- Part 22: Open font format
- Part 23: Symbolic Music Representation
- Part 24: Audio and systems interaction [Technical Report]
- Part 25: 3D Graphics Compression Model

#### Introduction

The main goal of this Technical Report is to facilitate a more widespread use of the MPEG-4 standard.

Design methodologies of the EDA industry have evolved from schematics to Hardware Description Languages (HDLs) to address the needs of the vast number of gates available on a single device. The increased number of gates allowed more elaborate algorithms to be deployed but also required a shift in design paradigm to handle the complexity created. Through HDLs, more complicated systems could be designed faster through the enabling technology of synthesis of the HDL code towards different silicon technologies where trade offs could be explored. Now the EDA industry again faces challenges where HDLs may not provide the level of abstraction needed for system designers to evaluate system level parameters and complexity issues. There have been a number of tool investigations under way to address this problem. Profiling tools aid in exposing bottlenecks in an abstract way so that early design decisions can be made. C to gates tools allow a C based simulation environment while also enabling direct synthesis to gates for hardware acceleration.

In conclusion, it is the aim of this Technical Report to enable more widespread use of the MPEG-4 standard through reference hardware descriptions and close integration with SO/IEC TR 14496-7 (MPEG-4 Part 7 Optimized Reference Software). Additionally, it is aimed that exposure to such a platform will enable a more systematic way to investigate the complexity of new codecs and open up the algorithm search space with an order of magnitude more compute cycles.



#### Information technology — Coding of audio-visual objects —

#### Part 9:

#### Reference hardware description

#### 1 Scope

This Technical Report specifies descriptions of the main video coding tools in hardware description language (HDL) form. Such alternative descriptions to the ones that are reported in ISO/IEC 14496-2, ISO/IEC 14496-5 and ISO/IEC TR 14496-7 correspond to the need of providing the public with conformant standard descriptions that are closer to the starting point of the development of codec implementations than textual descriptions or pure software descriptions. This part of ISO/IEC 14496 contains conformant descriptions of video tools that have been validated within the recommendation ISO/IEC TR 14496-7.

#### 2 Copyright disclaimer for HDL software modules

Each HDL module, and all derivative modules, shall be accompanied by the following copyright disclaimer:

Those intending to use this HDL module in hardware or software products are advised that its use may infringe existing patents.

The original developer of this HDL module and his/her company, the subsequent editors and their companies, and ISO/IEC have no liability for use of this HDL module or modifications thereof in an implementation.

Copyright is not released for non MPEG-4 Video conforming products.

<Company Name> retains full right to use the code for his/her own purpose, assign or donate the code to a third party and to inhibit third parties from using the code for non MPEG standard conforming products.

This copyright notice must be included in all copies or derivative works.

Copyright (c) <year>.

Module Name: <module name>.vhd

Abstract: